pCLAIMS 

1. A method of performing parity operations in a redundant data storage 
system that utilizes a plurality of data segments and at least two corresponding 
parity segments, wherein the parity segments are derived from the data segments 
and from parity coefficients corresponding yo respective data segments, and 
wherein there are different parity operations/ involving different subsets of the 
parity coefficients, the method comprising the following steps: 

pre-selecting parity coefficient subsets for use in the different parity 
operations; / 

storing all of the pre-selected parity/coefficient subsets in a memory; 

when performing a particular pamty operation, determining which of the 
stored subsets of parity coefficients is needed for the particular parity operation; 

reading the determined subset of parity coefficients from the memory; 

performing the particular parity operation with the subset of parity 
coefficients that was read from the memory. 

2. A method as recited in claim 1, wherein: 

the storing step comprises pre-formatting the pre-selected parity coefficient 
subsets in an indexed memory array; and 

the step of performing tne particular parity operation is accomplished by 
hardware-based parity operation logic that utilizes the subsets of parity 
coefficients as they are pre-fopiatted in the memory array. 

3. A method as recited in claim 1, further comprising: 
classifying the different parity operations into classifications comprising: 
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parity segment generation operations; 
parity segment regeneration operations; 
data segment reconstmcticp operations; 
wherein each classification of /parity operations includes a plurality of 
different classification scenarios, q^ch classifibation scenario involving a 
respective set of parity coefficients; 

wherein the pre-selecting ste|3 comprises pre-selecting parity coefficient 
subsets for each of the different classification scenarios; 

wherein the storing step cornprises pre-formatting the pre-selected parity 
coefficient subsets in an indexed memory array; and 

wherein the step of performing the particular parity operation is 
accomplished by hardware-based parity operation logic that utilizes the subsets of 
parity coefficients as they are pre-formatted in the indexed memory array. 



4. A method as recited in claim 1, further comprising: 
classifying the different parity operations into classifications comprising: 
parity segment generation operations; 
parity segment regeneration operations; 
data segment reconstruction operations; 
wherein each classification of parity operations includes a plurality of 
different classification scenarios, each classification scenario involving a 
respective subset of parity coefficients; 

wherein the pre-selecting step comprises pre-selecting parity coefficient 
subsets for each of tfie different classification scenarios; 
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wherein the storing step comprises grouping^ the pre-selected parity 
coefficient subsets in an indexed memory array/ in accordance with the 
classifications of the pre-selected parity coefficient subsets. 

5. A method as recited in claim 1, further comprising: 
classifying the different parity operations into classifications comprising: 
parity segment generation operations; 
parity segment regeneration/operations; 
data segment reconstruction operations; 
wherein each classification of parity operations includes a plurality of 
different classification scenarios/ each classification scenario involving a 
respective subset of parity coefficients, the subsets of parity coefficients having 
varying subset sizes; 

wherein the pre-selefcting step comprises pre-selecting parity coefficient 
subsets for each of the different classification scenarios; 

grouping the pre-selected parity coefficient subsets into classification 
groups; 

sub-grouptfig at least one of the classification groups into sub-groups 
according to subset size; 

whereftn the storing step comprises packing the pre-selected parity 
coefficiepr subsets in an indexed memory array, segregated by group and sub- 
group > 
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6. A method as recited in claim 1, wherefin the different parity 
operations include parity regeneration operations thai: include a plurality of 
different operation scenarios, each operation scenario involving a respective subset 
of parity coefficients, the respective subsets containing all possible ranges p* 
through p y of a base set of N parameter coefficients referred to as p 0 through p N . l? 
the method further comprising: 

7 forming groups of the subsets according to subset size; 

8 packing the groups of subsets in onjer of increasing subset size in a linear 
memory array; 

10 calculating an offset in the linear memory array of a particular group i 

11 corresponding to a subset size L,- in/accordance with a predefined function of N 

12 and L,; 

13 reading a subset of valued from the particular group corresponding to the 

14 subset size of L,- at the calculated offset in the linear memory array. 

15 

16 7. A method oi accessing pre-selected subsets of values, wherein the 

17 respective subsets contain all possible ranges p* through p y of a base set of N 
is values referred to as p 0 through p N . 1? the method comprising the following steps: 

19 forming groups of the subsets, wherein the groups correspond respectively 

20 to different subset sizes; 

21 packing the groups of subsets in order of increasing subset size in a linear 

22 memory arrdy; 

23 calculating an offset in the linear memory array of a particular group i 

24 corresponding to a subset size L,- in accordance with a predefined function of N 

25 and 
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reading a subset of values from the particular grqoip / at the calculated offset 
in the linear memory array. 

8. A method as recited in claim 7, wherein group i has N - L, + 1 
subsets of parity coefficients, and wherein th^ calculating step is performed by 
evaluating a formula comprising: 

((L/ - 1)(12N + (L,)(3M - 2L, - 5))/6) - 3(N - 1). 

9. A method as recited in claim 7, further comprising: 

within any individual group il calculating a memory offset of a subset D in 
the individual group as a function <z>f subset size L,-. 

10. A disk controlle/that performs parity operations in a redundant data 
storage system that utilizes a plurality of data segments and at least two 
corresponding parity segments, wherein the parity segments are derived from the 
data segments and frojri parity coefficients corresponding to respective data 
segments, and wherein there are different parity operations involving different 
subsets of parity coefficients, comprising: 

a memory containing stored subsets of parity coefficients corresponding 
respectively to different parity-related computation scenarios; 

hardware parity computation logic configured to any particular parity- 
related operation by (a) determining the scenario of the operation, (b) reading the 
corresponding subset of parity coefficients from the memory, and (c) performing 
the particular parity-related operation with the subset of parity coefficients read 
from the memory. 
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11. A disk controller as recited in claim 10, wherein the stored subsets 
are indexed within the memory. / 

12. A disk controller as recited in claim 10/wherein: 

the parity-related computation scenarios are/classified under classifications 
comprising: / 
parity segment generation operations; 
parity segment regeneration operations; 
data segment reconstruction Operations; 
the stored subsets are grouped/in the memory in accordance with the 
classifications of the corresponding parity-related computation scenarios. 

13. A disk controller as recited in claim 10, wherein: 

the parity-related computation scenarios are classified under classifications 
comprising: / 

parity segment generation operations; 
parity segment regeneration operations; 
data segment reconstruction operations; 
the stored .subsets are grouped in the memory into classification groups, in 
accordance with the classifications of the corresponding parity-related 
computation .scenarios. 

at one of the classification groups is sub-grouped according to size of its 
subsets. / 
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